## Memory hierarchy simulation programming

O. Prepare data structures for register\_file, cache, and main\_memory modules;

## Logic:

- 1. Read a machine instruction from input data file;
- 2. Decode (analyze) the instruction:
  - determine opcode (lw: 35, sw: 43);
  - determine rs and rt register numbers;
  - determine byte\_offset value;
- 3. Compute effective memory address (byte address) and convert it to a word address;
- 4. From the word address, compute cache index and tag values using MOD and DIV;
- 5. Search cache and do read/write operation, i.e., one of {read\_hit, read\_miss, write\_hit, write\_miss};
- 6. repeat step 1~5 for each instruction in the input data file (while loop until EOF).